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[57] ABSTRACT 

A system and method for auto-polling a status register 
within a physical layer (PHY) interface to a local area 
network (LAN). The system includes a host CPU which 
needs to detect and service interrupts generated by a PHY 
device on the LAN which is coupled between a first trans- 
mission medium (such as copper or fiber cable) and a 
management interface to the system. The system further 
includes an auto-polling unit which monitors activity on the 
management interface of the PHY device. When the auto- 
polling unit detects a lack of activity on the management 
interface of the PHY for a predetermined interval, the 
auto-polling unit reads a first value from the PHY status 
register. This first status value is then compared to a previ- 
ously stored value which corresponds to the last PHY status 
value read by the host CPU. If a mismatch is detected 
between these two values, an interrupt is generated to the 
CPU. In response to receiving the interrupt, auto-polling is 
suspended (to avoid changing the status data that caused the 
interrupt) and the CPU requests a read of the status value in 
the first register. In this manner, the CPU is able to access the 
status value which caused the interrupt and determine the 
appropriate course of action. This status read by the CPU 
also has the effect of clearing the interrupt. This system frees 
the CPU firom having to continually poll the PHY status 
register to determine if a change in status has occurred. 
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AUTO-POLLING UNIT FOR INTERRUPT location called a hub. This allows for easy modification of 

GENERATION IN A NETWORK INTERFACE the network (adding, deleting, moving computers) without 

DEVICE having to bring down the entire network. Furthermore, the 

entire network does not go down if one individual connec- 

FIELD OF THE INVENTION 5 tion is broken. 

This invention relates to the field of interface hardware for H ^ d topologies combining one or more of the above 

local area networks, and more particularly to a network DCtwork configurations may also be utilized to further 

interface which efficiently switches between different links mcreasc flexibility. 

to a local area network. * D order to permit a full range of data communications 

10 among disparate data equipment and networks, the Interaa- 

DESCRIPTION OF THE RELATED ART lional Standards Organization (ISO) developed a reference 

model known as Open System Interconnection (OSI) in 

Local area networks (LANs) have forever changed cor- 197 4 0S j is a seven-layer model which ideally allows 
porate and personal computing. First used for sharing simple standardized procedures to be defined, enabling the inter- 
information and resources among personal computer users, 15 connect i 0 n and subsequent effective exchange of informa- 
LANs have dramatically evolved over the last ten years to ^on between users. OSI defines the functions of each layer 
become the premier strategic computing platform for busi- bul foes not provide the software and hardware to imple- 
nesses today. All but the smallest corporations rely on LANs ment the mo del. The model's goal is to set a standard for 
and their dependence and appetite for this technology shows communication product vendors. The seven layers in 
no signs for slowing. Indeed, LANs have matured to the 20 sequence f rom top (i ayer 7) l0 bottom (layer 1) are as 
point of peer status with personal computers themselves. As follows: application, presentation, session, transport, 
the market and deployment of ever more powerful comput- network, data link, and physical. A given network does not 
ers continues to grow, the expectation of providing equally bave t0 implement each layer of OSI to be compatible with 
high performance network connectivity grows as well. m jg standard. 

One example of a local area network, LAN 10, is depicted 25 Uyer 7> the app ii cat i on i aye r, is responsible for special- 

in FIG. 1. As shown, LAN 10 includes a server computer 14 ized ne twork functions such as file transfer, virtual terminal, 

and a plurality of client computers 16. Computers 14 and 16 and electronic mail. The purpose of this layer is to serve as 

are coupled by LAN hardware 12, which includes the actual me wm d 0 w between correspondent application processes 

transmission medium (e.g., fiber-optic cable or copper cable wnich m the 0SI t0 exc hange meaningful data, 

such as unshielded twisted pair (UTP)) as well as various Examples of application layer protocols include SNMP, 

network hardware elements such as hubs, switches and RLOGIN, TFTP, FTP, MIME, NFS, and FINGER. Uyer 6, 

routers. me presentation layer, is responsible for data formatting, 

The advantages of LANs are numerous. By providing character code conversion, and data encryption of data 
easy access to shared data (on server computer 14, for 35 generated in the application layer. This layer is not always 
example), computer users are allowed to interpolate more implemented in a network protocol. Layer 5, the session 
effectively. Users are also able to share expensive peripheral layer, provides for negotiation and establishment of a con- 
devices such as printers, faxes and CD-ROMs between nection with another node. To do this, the session layer 
client computers 16. These peripheral devices are also provides services to (a) establish a session connection 
coupled to the various client computers via LAN hardware ^ Q between two presentation entities and (b) support orderly 
12. The cost of client computers may also be decreased by data exchange interactions. This includes establishing, 
lessening the needs for high-capacity disk drives on indi- maintaining, and disconnecting a communication link 
vidua! workstations. By storing data on one or more central between two stations on a network, as well as handling 
servers accessible through the LAN, this also provides an name-to-station address translation. (This is similar to plac- 
easier solution for backup of vital data. 45 ing a call to someone on the telephone network with 

A LAN includes two or more computer systems which are knowing only his/her name, wherein the name is reduced to 

physically and logically connected to one another. The type a phone number in order to establish the connection), 

of connection between the computer systems is referred to as Layer 4, the transport layer, handles the reliable end-to- 

the topology of the LAN. In a bus topology, computer end delivery of data. This layer ensures that data is delivered 

systems and devices are attached at different points along a 50 in the same order that it was sent. It also ensures that data 

bus. Data is then transmitted throughout the network via the is transmitted or received without error, and in a timely 

cable. The speed of transmission of the network is governed manner. Transmission control protocol (TCP) is a common 

by the type of cable. One disadvantage of this topology is transport layer protocol. Layer 3, the network layer, routes 

that a break in the cable disables the entire network. packets of information across multiple networks, effectively 

Furthermore, provisions have to be made for re -transmission 55 controlling the forwarding of messages between stations. On 

of data in cases in which multiple computers contend for the the basis of certain information, this layer will allow data to 

bus (cable) at the same time, causing data collision (and flow sequentially between two stations in the most economi- 

possible loss of data). cal path both logically and physically. This layer allows 

Another type of topology is the ring topology, in which units of data to be transmitted to other networks though the 

computer systems are daisy-chained together in a circle. In so use °f special devices known as routers. Internet Protocol 

such a configuration, data is transmitted from node to node (IP) is an example of a network layer protocol which is part 

(computer to computer). The data is passed from computer of the TCP/IP protocol suite. 

to computer until the correct destination is reached. While Layer 2, the data link layer, is responsible for transfer of 
this avoids the problem of data collision, a break in the addressable units of information, frames, and error check- 
connection disables the entire network. 65 ing. This layer synchronizes transmission and handles 
A third type of topology is the star topology. In this frame-level error control and recovery so that information 
configuration, all computer systems are routed to a central can be transmitted over the physical layer. Frame formatting 
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and cyclical redundancy checking (CRC), which checks for carry information up to 100m using Category 3 UTP wiring 
errors in the whole frame, are accomplished in this layer. It or better. UTP wiring comes in grades 1-7. Category 3 
also provides the physical layer addressing for transmitted wiring supports transmission rates of up to 16Mbps. Cat- 
frame. Serial Line IP (SLIP) and point-to-Point Protocol egory 5 cable, while more expensive, can support up to 
(???) are examples of data link protocols. Finally, layer 1, 5 100Mbps. Category 7 cable is the highest, most expensive 
the physical layer, handles the transmission of binary data grade of UTP cable, 
over a communications network. This layer includes the . , t . , , c . . , 
physical wiring (cabling), the devices that are used to V " c°u *T?/™lfc transmission 
connect a station's network interface controller to the ^ Jr thcrDCt f*? dard (J^E 802.3u) was cstab- 
wiring, the signaling involved to transmit/receive data, and in > lshcd ' n ra .^ d * C Ethc ™l b " S 
the ability to detect signaling errors on the network media. 10 fr ° m 10 Mbps to 100 Mbps with only minimal changes to 
ISO 2110, IEEE 802, and IEEE 802.2 are examples of * c c '?f l ! 1 Qg J CabIc Stru ^ rc ' ™ c f ast Ethernet standard had 
physical layer standards, ±c addcd advanta 8 c of **mg backward-compatible with the 
L , . . i . • • . i ■ 10Mbps Ethernet standard, allowing users to migrate to the 
For a bus or star topology, a transmission protocol is f , , . iL . . , b . . . _P ... 
„ r . nna * ' u,.~ »~ aJ^x „,;tK new standard without abandoning existing hardware. Like 
needed for devices operating on the bus to deal with the 1S . . . . 4 t , , „ . . , , , 
.A . II- • /. a . a . 15 the original Ethernet standard, Fast Etbe met includes several 
problem of data collision (two devices transmitting data over & t t . . ,. 1Anri ~ . 
f. . t v \-. « I . . , . . different transmission media. 100Base-T is a generic name 
the bus at the same time). One such technique implemented , 1An w. „ • , . • nC \AAjr-T\ i c 
■ .i. apt ■ n a • I.- i for 100Mbps twisted pair CSMA/CD proposals. Specific 
in the OSI data link layer is called earner sense multiple . *. . , 1A *1 D ™. , ; nn p n ™T 

/it- . fmiM * ir*r\\ it j .u- * u • proposals include 100Base-T4 and 100Base-TX. The 

access/collision detect (CSMA/CD). Under this technique, 100BASE T4 standard allows for su rt of 100 Mb 

hardware residing in a network interface card (NIC) within - n c . " * an ar a ° WS ^u^° ° r jr pS 

, . lt u f »u 0 Ethernet over Category 3 cable, but at the expense of adding 

a given computer system senses the voltage change of the . c • /A • • * a r .i. ~> • ac 

. & . c .f ... . . c , t , e u •. another pair of wires (4 pair instead of the 2 pair used for 

bus before attempting transmission of data. If no bus activity ^.J* P , .u- • i ^ _i_ j 

• j * . j .i. a . • . ■»* * . . 10BASE-T). For most users, this is an awkward scheme and 

is detected, the data is transmitted over the bus to the - *kmAcr ™ l. i~i i 

. ir , •■ . ji therefore 100BASE-T4 has seen little popularity. 100Base- 

appropnate destination. If bus activity is detected, however, ~-r t . , , . . i i <■ c 

*if xtt^ u u r j j t i TX, on the other hand, is the most popular solution for a 

the NIC holds off the access for a predetermined amount of » c .J WL , ... . . c r> . r n^r> 

. c . ... . * * , 2:> lOUMbps hthemet, utilizing two pairs or Cateeory 5 UTP 

time before re-trying the transmission. In such a manner, the r & r & / 

integrity of the transmitted data is preserved. & * 

Tie CSMA/CD technique is employed by a LAN protocol Even with 100Mbps Ethernet for LANs, new and existing 

known as Ethernet, which was developed by Xerox Corpo- aetw ° tk »PP>««tioiis are evolving to embrace htgh- 

ratioo in cooperation with DEC and Intel in 1976. Ethernet 30 « solu,,on <? a P blcs - video, and other neb media data types, 

uses a bus/ring topology and originally served as the basis Consequently pressure .s growmg throughout the network 

for IEEE 802.3, a standard which specifies the physical and ? r ln " ea , sed ^^ ^J exam P le> man y «PP^»» 

lower software layers. Ethernet technology is by far the most dema , nd ^^ib bandwidth networks to communicate 3D 

predominant networking protocol in use today, accounting visualizations of complex objects ranging from mo ecules to 

for some 80% of all installed network connections by 35 a^^ft. Magazmes, brochures and other complex, fuU- 

year-end 1996. All popular operating systems and applica- color pubhcations prepared on desktop computers are trans- 

tions are Ethernet-compatible, as are upper-layer protocol mM f , d ^. v . 10 *g«««l;mput printing facilities. Many 

stacks such as TCP/IP (UNIX, Windows, Windows 95), IPX me *« 1 facih ' ies lra f nsmit com P lex . una g es ? ver U ^ s - 

(Novell NetWare), NetBEUI (for LAN manager and Win- enablm 8 theshanngof expensive equipment and specialized 

dows NT networks) and DECnet (for Digital Equipment w med ' cal . «!>«?*• Engmeers are using electronic and 

Corp. computers). Other LAN technologies which are less mechamcal des.p automation tools to work interactively in 

popular than Ethernet include Token Ring, Fast Ethernet, distributed development teams, sharing files which hundreds 

Fiber Distributed Data Interface (FDDI), Asynchronous of gigabyte m sizes. Additionally, the explosion of Intranet 

Transfer Mode (ATM), and LocalTalk. Ethernet is the most '"hnology is leading to a new generation of multimedia 

widely utilized because of the balance it strikes between 45 d«nt/server applications utilizing bandw.dth-intensive 

speed, cost and ease of installation. aud J?> v ' deo ' and v ° ice ' ,D sho «. th f accelerating growth of 

t, . . a a * ac a u .u i * c LAN traffic is pushing network administrators to look to 

The Ethernet standard is denned by the Institute tor ... , \ . f , . . , , .... 

r-i . • i a n . • t- • /ir rn\ ir-r^o e. higher-speed network technologies to solve the bandwidth 

Electrical and Electronic Engineers (IEEE) as IEEE Stan- cr u ncn 

dard 802.3. This standard defines rules for configuring an mDC 

Ethernet as well as specifying how elements in an Ethernet 50 ^ Gi 8 abit Ethernet standard proposed in IEEE 802.3z 

network interact with one another. By adhering to the IEEE offere a migration path for Ethernet users. The IEEE 802.3z 

standard, network equipment and network protocols inter- slandard allows half ~ and f""-d"plex operation at speeds of 

operate efficiently 1000 Mb P s » relying on the 802.3 Ethernet frame format and 

Original UVNs based on Ethernet technology supported a CSMA/CD access method with support for one repeater per 

data transfer rale of up to 10 Megabits per second (Mbps). 55 collision domain Tlie Gigabit Ethernet standard is also 

IEEE 802.3 specifies several different types of transmission backward-compatible with lOBaseT and 100BaseT Ethernet 

media configured to meet this transmission rate. l0Base-2 is ecnnoiogies. 

a transmission medium which is capable of carrying infer- Much of lnc IEEE 802 3z standard is devoted to defini- 
mation via low-cost coaxial cable over distances of up to 185 lions of physical layer standards (PHYs) for Gigabit Ether- 
meters at 10Mbps. This is also referred to as "thin Ethernet". 60 aet - This standard uses the Fibre Channel-based 8b/10b 
"Thick Ethernet' 1 (10Base-5), conversely, is configured to coding at the serial line rate of 1.25 Gbps. Like other 
transmit up to distances of 500m over 50-ohm coaxial cable network models, Gigabit Ethernet implements functionality 
at this same rate. A fiber-optic standard, lOBase-FL, allows adhering to a physical layer standard. For Gigabit Ethernet 
up to 2,000m of multimode duplex cable in a point-to-point communications, several physical layer standards are 
link. The most popular wiring scheme at the 10Mbps rate, 65 emerging. 

however, is the lOBase-T standard, which utilizes twisted Two PHYs currently exist for providing Gigabit trans- 
pair conductors (also called UTP-unshielded twisted pair) to mission over fiber-optic cabling. A lOOOBase-SX is targeted 
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at low cost multimode fiber runs in horizontal and shorter 
backbone applications. lOOOBase-LX, meanwhile, is tar- 
geted at multimode fiber and single-mode fiber runs in 
longer backbone applications, such as building backbones or 
campus backbones. For multimode fiber, these standards 
define gigabit transmission over distances of 2 to 550 
meters, and for single-mode fiber, distances of 2 to 5000 
meters. 

There are also two standards efforts for Gigabit Ethernet 
transmission over copper cabling. The first copper link 
standard has been defined in IEEE 802 .3 z and is referred to 
as lOOOBasc-CX. This standard supports interconnection of 
equipment clusters where the physical interface is short-haul 
copper. It supports a switching closet or computer room as 
a short jumper interconnection for 25 meter distances. This 
standard runs over 150-ohm balanced, shielded, specialty 
cabling assemblies known as twin ax cable. This copper 
physical layer standard has the advantage that it can be 
generated quickly and is inexpensive to implement. 

The second copper link standard is intended for use in 
horizontal copper cabling applications. This standard is 
governed by the IEEE 802.03ab task force, which is char- 
tered with the development of a lOOOBase-T physical layer 
standard providing lGbps Ethernet signal transmission over 
four pairs of Category 5 UTP cable, covering distances up to 
100 meters or networks with a diameter of 200 meters. This 
standard, which uses new technology and new coding 
schemes in order to meet the potentially difficult and 
demanding parameters set by the previous Ethernet and Fast 
Ethernet standards, is expected to ratified sometime in late 
1998 or early 1999. The lOOOBase-T standard utilizes a PHY 
interface referred to as GMII ("Gigabit Medium Indepen- 
dent Interface"), which is similar to the Mil used in 
lOBase-T and lOOBase-X. GMII, however, provides a byte- 
wide interface as opposed to the nibble-wide interface of 
MIL Mil, GMII, and TBI are discussed in greater detail 
below. 

Regardless of the particular physical interface utilized in 
Ethernet, Fast Ethernet, or Gigabit Ethernet, the host CPU of 
the system requires access to a status register within the 
PHY device in order to monitor the state of the device. 
Device status is needed by the host CPU in order to 
determine if an interrupt condition is present (the link is 
down, for example). This status register is defined to be PHY 
register 1 (out of 31 possible) for both GMII and MIL (GMII 
also includes an Extended Status Register 15, however this 
only includes abilities of the device, and does not change 
during actual operation. This register is thus not utilized for 
detecting status). 

The interface to the management registers of a PHY 
device is described in IEEE Standard 802.3u clause 22 as a 
two- wire interface. The standard defines a bi-directional 
data line (referred to as "MDIO") and a clock signal 
("MDC"). These two signal make up the management 
interface to the PHY device. 

FIG. 2A depicts the CPU-PHY interface of a prior art 
computer system 100. As shown, system 100 includes a host 
CPU 110, a LAN controller 120, and a PHY device 130. 
Host CPU 10 is coupled to LAN controller 120 via a port 
112. In one embodiment this port may be a system bus 
coupled to controller 120 via a 10 bridge chip. LAN con- 
troller is coupled to PHY device 130 by interface 122, while 
CPU 110 is coupled to PHY 130 via a management interface 
including clock signal 132 and data line 134. Computer 
system is coupled to an external network 140 via a trans- 
mission medium 136, such as copper or fiber cable. 
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For interrupt determination within computer system 100, 
CPU 110 needs to determine if there has been a change in a 
status register within PHY device 130. Given the configu- 
ration of system 100, however, CPU 110 is required to 

5 continually poll the desired register via the MDC/MDIO 
interface of signals 132 and 134 to detect such a change. 
This method creates a drain on the bandwidth of CPU 110, 
particularly if the polling process returns infrequent status 
changes. Such polling thus may affect the overall system 

10 performance. 

This problem is also encountered in an alternate prior art 
embodiment shown in FIG. 2B. As shown, FIG. 2B depicts 
a computer system 150, which includes similarly numbered 
elements to computer system 100 of FIG. 2 A. Unlike 

15 computer system 100, however, CPU 110 of computer 
system 150 polls PHY 130 by signaling LAN controller 120 
via port 112. LAN controller 120, in turn, then polls PHY 
130 via the management interface bus of signals 132 and 
134. While this method avoids the direct CPU-PHY cou- 

20 pling of FIG. 2A, CPU 110 of FIG. 2B is still required to 
continually request polling information from LAN control- 
ler 130. Thus, the performance of computer system 150 is 
also sub-optimal. 
It would therefore be desirable to have a more efficient 

25 means of polling a status register of a physical layer inter- 
face device. 

SUMMARY OF THE INVENTION 

The present invention comprises a network interface 
system and method, such as a network interface card (NIC) 
within a computer system, which is configured to dynami- 
cally switch between a first physical layer device and a 
second physical layer device in establishing a network link. 
The first physical layer device is coupled to a first transmis- 
sion medium, while the second physical layer device is 
coupled to a second transmission medium. Both transmis- 
sion media are operable to establish a network link. Switch- 
ing may occur between the physical layer devices if an 
active link is determined to be down or unreliable. 

40 

The first physical layer device is one which requires a 
continuous connection to the computer system if active. A 
SERDES device is one example of such a device. If a 
SERDES device has established a connection with a link 
45 partner, the SERDES must be selected for active use by the 
NIC. In contrast, a G/MII device may establish a connection 
with a link partner without being selected for active use by 
the NIC. 

The NIC includes a link switching unit coupled to both the 
50 first physical layer device and the second physical layer 
device, as well as a physical layer interface unit coupled to 
the link switching unit. The NIC further includes a control 
unit configured to generate a select signal indicative of 
whether the first physical layer device or the second physical 
55 layer device is currently selected. This select signal is then 
conveyed to the link switching unit and the physical layer 
interface unit. 

The link switching unit is configured to transfer data 
between the physical layer interface unit and a currently 

60 selected physical layer device indicated by the select signal. 
The link switching unit is also coupled to the physical layer 
interface unit, which in turn couples to an external interface 
of the network interface card. The external interface con- 
nects the NIC to a remainder of the network device, e.g., a 

65 computer system. 

The physical layer interface unit is configured to transfer 
data between the link switching unit and the external inter- 
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face. The physical layer interface unit receives incoming 
data from both the external interface and the link switching 
unit. The interface unit includes a first physical layer inter- 
face sub-unit and a second physical layer interface sub-unit. 
The first physical layer interface sub-unit is configured to 5 
process the incoming data according to an interface of the 
first physical layer device, while the second physical layer 
interface sub-unit is configured to process the incoming data 
according to an interface of the second physical layer device. 
Both sub-units generate outgoing data in response to the JQ 
incoming data. The physical layer interface unit then selects 
the appropriate outgoing data in response to the currently 
selected physical layer device. 

[n one embodiment, the first physical layer device is a 
SERDES device and the second physical layer device is a 
G/MII device. Accordingly, in such an embodiment, the first 15 
physical layer interface sub-unit is a physical coding sub- 
layer and the second physical layer interface sub-unit is a 
G/MII reconciliation sublayer. 

Dynamic switching may occur either from the first physi- 
cal layer device to the second physical layer device or 20 
vice-versa. In order to switch from the first physical layer 
device to the second physical layer device, an indication is 
sent that the link established through the first physical layer 
device is going off-line. This ensures that link partners are 
notified of the pending change in link status. Next, the first 25 
physical layer device is put into isolation. The link unit is 
then switched from coupling to the first physical layer 
device to the second physical layer device. This establishes 
a connection from the second physical layer device to the 
physical layer interface unit via the link switching unit. The 30 
physical layer interface unit is then signaled that incoming 
data corresponds to an interface specified by the second 
physical layer device. Accordingly, the outgoing data gen- 
erated by the second physical interface sub-unit is now 
selected. This establishes a connection from the link switch- 35 
ing unit to the external interface of the NIC via the physical 
layer interface unit. Finally, the second physical layer device 
is configured and de-isolated; A network connection may 
now be established via the second physical layer device. 

In order to switch from the second physical layer device 40 
to the first physical layer device, the process is similar. First, 
an indication is sent that the link established through the 
second physical layer device is going off-line. Next, the 
second physical layer device is put into isolation. Then the 
physical layer interface unit is signaled that incoming data 45 
corresponds to an interface specified by the first physical 
layer device. Accordingly, the outgoing data generated by 
the first physical interface sub-unit is now selected. This 
establishes a connection from the link switching unit to the 
external interface of the NIC via the physical layer interface 50 
unit. Next, the link unit is switched from coupling to the 
second physical layer device to the first physical layer 
device. This establishes a connection from the first physical 
layer device to the physical layer interface unit via the link 
switching unit. Finally, the first physical layer device is 55 
configured and de-isolated. A network connection may now 
be established via the first physical layer device. 

This system provides a smooth migration path for net- 
work users of LANs which include both fiber-optic and 
copper transmission media. By having the capability to 60 
switch between a number of devices (including a fiber-optic 
device such as a SERDES device), network responsiveness, 
reliability and flexibility are enhanced. In addition, the 
present invention allows improved rendering of network 
interfaces using a single NIC. The system can be configured 65 
to monitor the active link and dynamically switch between 
PHYs for improved redundancy. 
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The present invention also comprises a system and 
method for monitoring a currently established network link. 
In prior art systems, a host CPU in a computer system is 
required to continually poll a register in a network interface 
card in order to test the status of the currently established 
link. This has the disadvantage of becoming a drain on the 
bandwidth of the host CPU, particularly if the polling does 
not frequently result in retrieval of updated status values. 
This decrease in bandwidth adversely affects system perfor- 
mance. 

In one embodiment, the present invention includes a 
system for auto-polling to determine the current link status. 
This system includes a host CPU and a network interface 
card (NIC), wherein the NIC includes, a physical layer 
device and an auto-polling unit. The physical layer interface 
device is coupled to a network via a first transmission 
medium. Control values for this device may be changed via 
a management interface (such as the MDIO/MDC interface 
defined by IEEE standard 802 3u, clause 22). Status values 
for the device are included within a designated status 
register. 

The auto-polling unit is configured to monitor activity on 
the management interface of the physical layer interface 
device. If no activity is detected on the management inter- 
face for a predetermined period of time, the auto-polling unit 
reads a first status value from the status register of the 
physical layer interface device. (The predetermined period 
of time may be a predefined constant, or may be varied by 
the host CPU). This first status value is then compared to a 
second status value. This second status value is the last 
physical layer status value read by the host CPU. 

If the first and second status values are the same, the 
auto-polling continues monitoring activity on the manage- 
ment interface of the physical layer interface device. If there 
is a mismatch between the first and second status values, 
however, an interrupt is generated to the host CPU. The host 
CPU, in turn requests a read of the first status value (that is, 
the data which caused an interrupt to be generated). The read 
performed by the CPU causes the interrupt to be de-asserted. 

Because the network interface card in this system signals 
the host CPU whenever an interrupt condition has been 
detected, the CPU does not have to waste bandwidth by 
continually polling network interface devices. This leads to 
a more efficient use of system resources, particularly CPU 
bandwidth. The auto-polling method used in this system thus 
results in increased overall system efficiency and perfor- 
mance. 

BRIEF DESCRIPTION OF THE DRAWINGS 

A better understanding of the present invention can be 
obtained when the following detailed description of the 
preferred embodiment is considered in conjunction with the 
following drawings, in which: 

FIG. L is block diagram of a prior art local-area network; 

FIGS. 2A-B are block diagram of prior art CPU-PHY 
interfaces; 

FIG. 3 is a high-level block diagram of a computer system 
which includes a network interface card according to one 
embodiment of the present invention; 

FIGS. 4A-B depicts different LAN configurations which 
include computer systems having network interface connec- 
tions according to one embodiment of the present invention; 

FIG. 5 is a high-level block diagram of a network inter- 
face card which includes a link switch unit between a 
SERDES and G/MII devices according to one embodiment 
of the present invention; 
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FIGS. 6A-C depict how the OSI reference model sub- including uniprocessors and multiprocessors. Similarly, host 

layers map to the PHY interfaces used by different trans- bus 203 may be any of a variety of high-speed buses 

mission media; designed for communication between host processors, 

FIG. 7 is a more detailed block diagram of network memory subsystems, and specialized subsystems, 

interface card 312 depicted in FIG, 4 according to one 5 Bus bridge unit 205 couples to a system memory 204 (via 

embodiment of the present invention; a memory bus 206), graphics controller 208 (via a pixel bus 

FIGS. 8A-B are block diagrams of the interface to the 210), and various IO devices (via an 10 bus 214). Main 

link switch unit depicted in FIG. 5 according to one embodi- memory 204 may be any of various types of memory 

ment of the present invention; subsystems, including random access memories (RAMs) 

FIG. 9 is a high-level flowchart describing the monitoring 10 and mass stora 8 c dcviocs - 

operations of network interface card 312 according to one In the embodiment shown in FIG. 3, graphics accelerator 

embodiment of the present invention; or video device 208 is coupled to host CPU 202 via bus 

FIG. 10 is a flowchart of the link switch operation brid S e unit 205 - Graphics accelerator 208 is configured to 

performed by network interface card 312 according to one render P lxeI received via bus 205. The pixel data 

embodiment of the present invention; rendered b V S ra P hics controller 208 is converted to a video 

™„ . . c , . t r i signal for display on device 226 (which may be, in one 

FIG. 11 is a block diagram of a network interface card & . # ,♦• A i * \ n u a . *>n* 

...... . ir ** a- * embodiment, a multi-display system). Bus bridge unit 205 

which includes an auto-polling unit according to one . .* • ,/ ; , j • • mt 

... c , • .• also couples to one or more input/output devices via IO bus 

embodiment of the present invention, 2M (which may be & pa bus ^ Qne embodiment) M shown 

FIG. 12 is a state machine which illustrates operation of 20 in RG 3 10 bus 2U les tQ DetWQrk mterface ^ 2U 

an auto-polling unit according to one embodiment of the and genefic 1Q deyice 215 

present invention. Network interface card 212 provides computer system 

FIG 13 is a flowchart which depicts the flow of the m wim Qne Qf mor£ lmks tQ an attacQed ^ ( 

auto-poll operation according to one embodiment of the alternately, different LANs or MANs). As will be described 

present invention; and below ^ me one 0f more Unks provided by mc tn may te 

FIG. 14 is a flowchart depicting the operation of the host coupled to different transmission media (that is, different 

CPU during auto-polling according to one embodiment of of physical cabling). NIC 212 is thus configured to 

the present invention. receive network data and convert this received data into a 

While the invention is susceptible to various modifica- ^ format recognizable by the software-implemented portions 

tions and alternative forms, specific embodiments thereof of the chosen communications protocol. Conversely, NIC 

are shown by way of example in the drawings and will 212 is also configured to receive outgoing data, format this 

herein be described in detail. It should be understood, data accordingly, and transmit the formatted data over the 

however, that the drawings and detailed description thereto chosen network interface. 

are not intended to limit the invention to the particular form ^ Generic IO device 215 is representative of other types of 

disclosed, but on the contrary, the intention is to cover all I0 devices which may be attached to bus 214. In one 

modifications, equivalents and alternatives falling within the embodiment, device 215 may be a SCSI interface to mass 

spirit and scope of the present invention as defined by the storage of computer system 200. IO bus 214, in one 

appended claims. embodiment, also couples to a secondary bus 220 via a 

DETAILED DESCRIPTION OF THE « ?^ d ^ bus b u rid f uni < 2 }<> In u an embodiment in which 

rK^nnikxcvrrc mo i n c»,ci* m IO bus 214 is a high-speed bus such as a PCI bus, secondary 

EMBODIMENTS FIG. 3 — Computer System , , toa,t-ioal_ l u , , „ t - „ 

r J bus 220 may be an ISA/EISA bus which couples to "native" 

FIG. 3 depicts a computer system 200 which includes a \q devices 218 (such as a keyboard, a mouse, or other 

network interface card (NIC) according to one embodiment position tracking devices). 

of the present invention. The present invention may be used 4$ ^ described above, NIC 212 is configured to provide 

in any of various types of network devices, including dynamic switching between different physical layer devices, 

computer systems, networked printers, hubs, switches, Different LAN configurations which may utilize such a NIC 

routers, etc. In the following description the present inven- are snown ^ re f er ence to FIGS. 4A-B, while FIGS. 5-10 

tion is described with reference to a computer system. discuss the operation of NIC 212 and the dynamic switching 

As will be described in greater detail below, the NIC 50 process in greater detail, 
within computer system 200 is configured to dynamically 

switch between different network interfaces to a local-area FIGS. 4A-B— LAN Configurations With 
network (LAN). This switch operation may couple the NIC Redundant Links 
to a second network link in response to a first network link ^ described above, a network interface card according to 
being detected as down or unreliable. 55 ^ preS ent invention (such as NIC 212 shown with refer- 
As used herein, the terms "dynamically switching" and ence to FIG. 3) may be utilized to provide two or more links 
"dynamic switch" refer to the fact that the NIC of computer between a computer system and a network. This allows the 
system 200 can perform on -the -fly switching between a first computer system to switch links if a currently selected link 
network interface and a second network interface. No inter- is detected to be down or unreliable. This is particularly 
vention from a user of computer system 200 (or a network 60 useful in the case of migration into a newer technology 
administrator) is required. This switching may thus be transmission medium that may not be as reliable as an 
performed automatically as needed. This allows system 200 existing link. A network interface card configured according 
to seamlessly shift to a second network interface if a first to one embodiment of the present invention allows dynamic 
network interface is down or becomes unreliable. switching of one link to a second link if a fault on the 
As shown, computer system 200 includes a host CPU 202 65 currently selected link is detected. This advantageously 
coupled to a bus bridge unit 205 via a CPU bus 203. CPU increases network flexibility and reliability. Many LAN 
202 may be any of various types of computer processors, configurations are possible using a network card according 
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to one embodiment of the present invention. 1\vo such multiplexer unit 326, switch 322 A and fiber-optic server 

configurations, LANs 300A-B, are shown below with ref- connection 320A. If switch 322A becomes unreliable, server 

ere nee to FIGS. 4A-B. computer 302 can establish a new network link via UTP 

FIG. 4A depicts a LAN 300A. LAN 300A includes a server connection 320B. Thus, communications can be 

server computer 302, which is coupled to a switch 306 via $ restored to client computer 312C and server 302 by coupling 

dual server connections 304A-B. Server computer 302 "> switch 322B, multiplexer unit 326 and hub 310. 

couples to these dual server connections 304 via a network [ n pr i or art systems, an on -the- fly switch cannot be 

interface card 212. Switch 306 also couples to dual server performed between a fiber-optic connection and a copper 

connection 304 via its own NIC. The NIC 212 within switch connection (such as the unshielded twisted pair connection 

306 couples, in turn, to switch hardware 308. Switch hard- 10 32OB shown in FIG. 4B). Network interface card 212, 

ware 308 provides connectivity to the remainder of LAN however, is configured to dynamically handle this type of 

300A. Specifically, switch 306 couples to client computers switch. A migration path using fiber-optic transmission 

312 A-E and hub 310. Client computers 312A and 312E are media can thus be realized without compromising system 

directly connected to switch 306, while client computers reliability, efficiency and performance. 

312B-D are coupled to switch 306 via hub 310. 15 

In one embodiment, server connection 304A is the cur- FIG. 5 — Network Interface Card Block Diagram 
rently selected link within server 302. Accordingly, a given 

client computer 312 couples to server 302 over server Referring now to FIG. 5, a block diagram of NIC 212 is 

connection 304A. This is accomplished by the given client depicted. As shown, NIC 212 includes a media access 

computer 312 being selected by switch 306. Data is then 20 controller (MAC) device 410, a select generation unit 414, 

transferred through switch hardware 308 to NIC 212, and a link switch 420, a SERDES PHY device 430, and a G/MII 

then on to server computer 302. (Conversely, data can also PHY device 440. MAC device 410 couples to computer 

be transmitted from server connection 304A through NIC system 200 via IO bus 214, and includes a physical layer 

212 and switch hardware 308 to a given client computer (PHY) interface unit 412 for coupling to link switch 420. 

212) 25 Select generation unit 414 generates a select signal 416, 

If server connection 304A is detected to be unreliable, w °jch is conveyed to physical interface unit 412 and link 

however, NIC 212 within server 302 may receive a com- s ™ tch ™« 42 ° As will be described below, select signal 

mand which instructs NIC 212 to deactivate server connec- * as f rled « orde ; 10 P^°[ m ^mic swit ching 

tion 304A and activate server connection 304B. In such a 3Q between physical layer devices 430 .and I 44* Link swatch 

case, a switching procedure (described in greater detail 30 umt 420 couples to PHY devices 430 and 440 via a pair of 

below) is performed. This switching procedure has the effect and receive buses. 

of establishing a network link between server 302 and SERDES PHY device 430 couples to a local-area network 

switch 306 over server connection 304B. Client computer (such as LAN 300A or B) via a fiber-optic transmission 

312A-E now couple to server computer 302 via this newly 35 medium (lOOOBase-X, for example). In contrast, G/MII 

established connection. PHY device 440 couples to LAN 300 via a copper trans- 

Becausc NIC 212 within server 302 is configured to mission medium (such as 10/1 OOBase-T). PHY devices 430 

perform dynamic switching, the reliability of the LAN is not and 440 each have a different physical layer interface, 

compromised. In fact, users of LAN 300A may not notice a Device 430 has a ten-bit interface (TBI), while device 440 

loss in connectivity to server 302 (although if server con- 40 has either a byte-wide or nibble-wide (GMII or Mul) inter- 

nection 304B is slow relative to server connection 304A, a face. Moreover, the OSI reference model sublayers map 

difference in latency may be noticed). Although prior art differently into the SERDES and G/MII devices, further 

network interface cards also allow on-the-fly switching, complicating the switching process. This difference in PHY 

network interface card 212 has the added advantage of being interfaces is described next with reference to FIGS, 6A-C. 

able to switch between links which include a fiber-optic 45 

interface (such as a SERDES device). FIGS. 6A-C— OSI Sublayer Mappings for 

FIG. 4B illustrates a different LAN configuration, LAN Different Ethernet Protocols 

300B. LAN 300B increases the robustness of the configu- _ . irvr) ~ , ir4nr> v DUV 

. AA . ... , . . a„ In the 1 0B ase-T and 100Base -X protocols, PHY devices 

ration shown in FIG. 4A by including dual switches. As . t . , . . _ r „ . m ' /D w AX . 

7 r *x r ™<in • i j . mi u • u * ™ incorporate the physical medium attachment (PMA) and 

shown LAN 300B .includes a server computer 302 wh.ch ,s so ^ £ ?J ^ ^ (o ^ 

coupled to a plural.ty of sw.tches 322. Server 302 _« coupled ^» ^ njt / Wc . v wide ; M1I . similarl 100 OBase-T 

to switch 322 A by fiber-opt ic server connection 320A, while „. ... , ... ( . nx , . n , 

. , , . . ,-,-»r. L nm PHY devices also incorporate the PMA and PCS layers and 

server 302 is .coupled to switch 322 B by UTP 'server ^ MAC device 410 via the byte-wide GMII. 

connection 320B. Server 302 again includes a network 100 0Base-X PHY device (SERDES), however, the 

interface card 212 according to one embodiment of the 55 pcs inc [ed . Inslead( lhe PCS for a SERDES 

present mvenuon, thus providing dual links over server ^ F ^ ^ 

connections 320A-B. Switches 322 each include a network Accordingly, IEEE 802.3z standard specifies a 

interface card that supports only a single ^Switches » > be ^ SERD£S 

322A-B provide redundant paths between a switch 326, v ^ 

router 328, hub 327, and server 302. This provides increased 60 device 430 and MAC device 41U " 

system reliability as opposed to the configuration of LAN The pins required for the Mul are a subset of the pins 

300A shown above. If switch 306 of FIG. 4A fails, for required for the GMII. Both Mil and GMII use the same 

example, the entire network is disabled. In the configuration management interface pins, MDIO and MDC (discussed in 
of LAN 300B, however, the use of dual switches 322 allows greater detail below). The TBI is not related to either Mil or 

total network operation even if one of the switches is not 65 GMII, but IEEE 802.3z specifies a mapping of the pins on 
functioning. Consider the case in which client computer the TBI to pins on the GMII and MIL Table I depicts this 
312C is coupled to server computer 302 via hub 310, mapping. 



07/27/2003, EAST Version: 1.04.0000 



6,065,073 



13 



14 



TABLE 1 




Pin Mapping 




Mil 


GMII 


TBI 


TX_ER 


TX_ER 


TX<9> 


TX_EN 


TX_EN 


TX<8> 




TXD<7:4> 


TX<7:4> 


TXD<3:0> 


TXD<3:0> 


TX<3^h> 


RX_ER 


RX_ER 


RX<9> 


RX_DV 


RX_DV 


RX<8> 




RXD<7:4> 


RX<7:4> 


RXD<3:0> 


RXD<3:0> 


RX<3:0> 
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Although the data and control pins on the Mil, GMII and 
TBI can be mapped to equivalent pins, there are differences 
in how the Mil and GMII pins operate in comparison to the 
TBI pins. For example, upon power-up, a SERDES device 
needs the PCS via the TBI to either auto-negotiate with its 
link partner or to transmit idle codes. The SERDES device 
requires the PCS to perform auto-negotiation. Thus, if the 
SERDES device is to be the selected interface, the TBI 
interface within NIC 212 is also active upon power-up. 

If the TBI is active upon power-up, the Mil and GMII, on 
the other hand, are inactive. However, since the PCS for 
these PHY devices are located internally, the PHYs them- 
selves can perform auto-negotiation (or transmit idle codes). 
G/MI1 devices may thus establish a connection with a link 
partner even if they are not selected as the current network 
connection. A SERDES device, conversely, requires a con- 
tinuous connection: either the SERDES is inactive or it is the 
currently selected network connection. 

Because of the different properties of G/MII and SERDES 
devices, prior art devices have not been able to perform 
dynamic switching between the two interfaces. Instead, 
switching has been performed during power-up. While this 
simplifies the design of the network interface card, this does 
not provide a smooth migration path for a network user. For 
instance, such a design does not allow a user with an Mil 
device (10BASE-T or 100BASE-X) to migrate to a TBI 
device (lOOOBase-X). A network interface card according to 
one embodiment of the present invention, however, allows 
such a migration path. 

FIG. 7— DetaUed Network Interface Card Block 
Diagram 

FIG. 7 depicts a more detailed block diagram of NIC 212, 
FIG. 7 includes a number of elements depicted above with 
reference to FIG. 5: PHY interface unit 412, select genera- 
tion unit 414, link switching unit 420, SERDES PHY device 
430, and G/MII PHY device 440. As shown, NIC 212 also 
includes a control unit 500, which couples to IO bus 214. 

As shown, control unit 500 is configured to generate four 
control signals for conveyance to select generation unit 414: 
switch data input signal 505, switch write enable signal 506, 
interface select data 507, and interface select write enable 
508. Control unit 500 also provides a data path between IO 
bus 214 and physical interface unit 412. Control unit 500 
provides input data to unit 412 via control-interface input 
bus 502, while control unit 500 receives input data from unit 
412 on interface-control output bus 504. 

Select generation unit 414 generates the signals utilized to 
switch the proper physical layer interface as well as the 
physical layer device itself. Switch output data signal 538, 
which controls the switching of link switching unit 420, is 
generated by flip-flop 534 in response to inputs switch input 
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data signal 505 and switch data write enable signal 506. 
Interface select signal 536, which enables the appropriate 
physical layer interface, is generated by flip-flop 534 in 
response to inputs interface select data 507 and interface 
select write enable 508. The initial state of output signals 
536 and 538 is determined after reset signal 502 is 
de- asserted (according to whether SERDES device 430 is 
powered-up as indicated by SERDES in use signal 550). 

Physical interface unit 412 includes a corresponding 
sublayer unit for each of the types of attached PHY devices. 
Physical Coding Sublayer 514 corresponds to the MAC 
interface for SERDES PHY 430, while Reconciliation sub- 
layer 516 corresponds to the MAC interface for G/MII 
devices. Sublayers 514 and 516 share a common interface to 
control unit 500: control-interface input bus 502. Thus, 
when control unit 500 receives PHY input data from bus 
214, this data is conveyed on bus 502 to both sublayer 514 
and sublayer 516. Only one sublayer at a time is active, 
however, based on the state of interface select signal 536. In 
the embodiment shown, a '1' value causes sublayer 514 to 
be enabled, while a '0* value on signal 536 enables sublayer 
516. 

The enabled sublayer (514 or 516) processes the input 
data received on bus 502 and conveys output data on a 
corresponding bus 520. (Sublayer 514 conveys output data 
on first PCS output bus 520A, while sublayer 516 conveys 
output data on first reconciliation sublayer output bus 
52013). The data on buses 520A-B is conveyed to output 
multiplexer 512B. Output multiplexer 512B provides an 
input data path (Link switch input bus 524) between PHY 
interface unit 412 and link switching unit 420. The output of 
multiplexer 512B is also selected by the state of interface 
select signal 536. 

Link switch output bus 522 provides an output data path 
from link switching unit 420 to physical interface unit 412. 
Bus 522, like bus 502, couples to both sublayer 514 
(SERDES) and sublayer 516 (G/MII). The active sublayer 
(determined by signal 536) then processes the input data 
from bus 522, and conveys corresponding output data on a 
corresponding bus 518. (Sublayer 514 conveys output data 
on first PCS output bus 518A, while sublayer 516 conveys 
output data on first reconciliation sublayer output bus 518B). 
The data from both buses 518 is conveyed to an output 
multiplexer 512A, which conveys its output data on 
interface -control output bus 504 to control unit 500, Like 
multiplexer 512B, multiplexer 512A conveys output data 
based on the state of interface select signal 536. 

Link switching unit 420 provides a data path between 
physical interface unit 412 and PHY devices 430 and 440 
according to the state of switch signal 544. Switch signal 
544 is generated by OR gate 542 in response to inputs switch 
data output signal 538 and SERDES not in use signal 541, 
which is generated by inverter 539 from SERDES in use 
signal 550. In the embodiment shown, link switching unit 
420 is configured to switch to SERDES PHY 430 in 
response to switch signal 544 being equal to '0'. Conversely, 
when signal 544 is ' T, unit 420 switches to G/MII PHY 440. 
Many other embodiments of NIC 212 are possible in which 
link switching unit 420 is controlled in alternate manners. 

Table 1 shown above depicts the common pins between 
the Mil, GMII, and TBI. The common output pins are 
conveyed on link switch input bus 524 to link switching unit 
420. The routing of these signals within unit 420 is described 
below with reference to FIG. 8 A. 

There are some pins, however, that are present in the 
G/MII which are not present in the TBI. These G/MII -only 



07/27/2003, EAST Version: 1.04.0000 



6,0 

15 

pins are therefore directly connected (through unit 420) 
between physical interface unit 412 and G/MII PHY 440 at 
all times. For example, the G/MII PHY input signal GTX- 
CLK is connected directly from unit 412 to G/MII PHY 440. 
GTXCLK is part of link switch input bus 524 and G/MII 
input bus 542B. Similarly, G/MII PHY output signal 
TXCLK is not switched by unit 420 either. TXCLK is part 
of G/MII output bus 542A and link switch output bus 522. 
There are also several SERDES signals that are shared. 

FIGS. 8A-8B— Link Switching Unit 

As described above, link switching unit 420 couples the 
current selected PHY (as determined by the value of switch 
signal 544) to physical layer interface unit 412. In one 
embodiment, link switching unit 420 includes a transmit 
data path (from unit 412 to PHYs 430 and 440) and a receive 
data path (from PHYs 430 and 440 to unit 412). FIG. 8A 
depicts the transmit data path, while FIG. 8B depicts the 
receive data path. 

As shown in FIG. 8A, the transmit data path includes link 
switch input bus 524 conveyed from physical layer interface 
unit 412. Bus 524 includes all the component transmit 
signals of the Ten-Bit Interface (TXD0-9), along with other 
G/Mll-specific signals. Note that several of the G/MII 
defined signals are mapped onto TBI-defined signals. For 
example, G/MII signal TX_ER and TXD8 are conveyed on 
the same signal of bus 524, depending upon which interface 
is enabled. 

The commonly shared signals of bus 524 are conveyed to 
a transmit switch 610 within link switching unit 420. In a 
preferred embodiment, transmit switch 610 (and receive 
switch 612 described below) are implemented with a high- 
speed switch which exhibits minimum-to-zero propagation 
delay and ground bounce, while still providing adequate 
drive capability. In one embodiment, the QS33X257 Quick- 
Switch from Quality Semiconductor is utilized for switches 
610 and 612. 

As shown, transmit switch 610 receives switch signal 544. 
As described above, in one embodiment, if switch signal 544 
is a '0*, transmit switch 610 conveys shared input bus 524 
signals on SERDES PHY input bus 540B (also denoted as 
bus IOA-J at switch 610 outputs). Conversely, if switch 
signal 544 is a • 1\ transmit switch 610 conveys shared input 
bus 524 signals on G/MII PHY input bus 542B (switch 
outputs IIA-J). The G/MII -specific signal are conveyed 
directly to PHY 440 using the non-shared portions of buses 
522, 524, 542A, and 542B. 

As shown in FIG. 8B, the receive data path includes 
SERDES output bus 540A and G/MII PHY output bus 542A 
conveyed to link switch unit 420. Buses 540A and 542A 
represent the common signals which are switched by receive 
switch 612. Bus 540A includes all the component receive 
signals of the Ten-Bit Interface (RXD0-9). Bus 542 includes 
several G/MII-specific receive path signals in addition to the 
shared signals. 

Receive switch 612 receives switch signal 544 in the same 
manner as transmit switch 610. If switch signal 544 is a '0', 
receive switch 612 conveys input bus 540A signals from 
SERDES PHY 430 to PHY interface unit 412 on link switch 
input bus 522. The SERDES specific signals are conveyed 
directly to unit 412 on non-shared portions of buses 540A 
and 522. Conversely, if switch signal 544 is a *1\ receive 
switch 612 conveys input bus 542B signals from G/MII 
PHY 440 to PHY interface unit 412 on bus 522. The 
G/MII-specific signals are conveyed directly to unit 412 40 
using non-shared portions of buses 542A and 522. 
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FIG. 9-^System-Level Flowchart 

FIG. 9 depicts a method 700 which describes the overall 
operation of computer system 200 with regard to detection 
of network link status. Generally speaking, method 700 may 

5 be generalized into two parts. In the first part of method 700, 
the link is monitored in step 712. If a timeout or lost link is 
reported, a series of steps (714-732) arc taken to correct the 
potential fault. 
Method 700 begins with step 712, in which the status of 

10 the link is monitored. Link monitoring may be performed in 
a variety of ways. One common way is for host CPU 202 to 
poll a status register in the currently established physical 
layer device at a predetermined interval. A link monitoring 
method which uses auto-polling to advantageously free up 

15 CPU bandwidth may also be employed. This process is 
described below with reference to FIGS. 11-14. 

Regardless of the monitoring method employed in step 
712, the polling process periodically checks the link status. 
This operation is represented by step 714 in method 700. If 

20 no fault is detected, the link is reported active in step 732. 
Method 700 then returns to step 712 and the monitoring 
process resumes. 
If, however, the link has a potential fault, method 700 

25 proceeds to step 716. In this step, host CPU 202 receives an 
interrupt to indicate that the current link is possibly faulty. 
Next, in step 718, a determination is made by host CPU 202 
of whether or not to perform a link switch. To this end, CPU 
202 may consult a previously generated table which indi- 

J0 cates if other PHYs are available for switching. 

If it is determined in step 718 that a link switch is to be 
performed, method 700 proceeds to step 720, in which the 
switch operation is effectuated. This process is described in 
greater detail with reference to method 800 in FIG. 10. After 

J5 the switch operation in step 720 completes, method 700 
proceeds to step 722. If it is determined in step 718 that a 
link switch is not to be performed, method 700 proceeds 
directly to 722. 

In step 722, it is known that an interrupt has previously 

4 q been generated due to a link timeout or status mismatch. 
This interrupt condition may have caused a link switch 
(execution of step 720) or the previous link may still be 
selected (having bypassed step 720). In either case, the 
currently selected link (whether new or old) is reconfigured 

45 starting in step 722. 

In step 722, a determination is made as to whether the link 
is to be brought in manual configuration mode or by auto- 
negotiation. In manual configuration mode, link parameters 
are specified by host CPU 202, while auto-negotiation mode 

50 allows link partners to perform automatic configuration of 
an established link. This determination is typically made by 
querying a bit (or variable) set in the network driver being 
executed by host CPU 202. 

If the driver settings indicate that manual configuration 

55 mode is desired, method 700 proceeds to step 728. In step 
728, manual configuration is performed, with host CPU 
specifying parameters such as line and wire speed. Next, in 
step 730, a determination is made as to whether the link is 
active. If activity is delected, this is noted in step 732. 

6o Execution of method 700 then continues with monitoring of 
the link in step 712. If the link is determined to be inactive 
in step 730, method 700 proceeds directly to step 712, with 
the link being monitored to check for a timeout or fault 
condition (which 27 If or example, if the link cannot be 

65 properly established). 

If the driver settings indicate that auto-negotiation is 
desired, method 700 proceeds from step 722 to step 724. In 
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step 724, a determination is made as to whether the physical face unit 412. Next, in step 824, a '0* value is written to 

device being configured is ready (that is, it has completed switch input data signal 505 by control unit 500. This causes 

auto-negotiation). If auto-negotiation has completed, switch output data signal 538 to become a '0', which, as 

method 700 advances to step 730 to check to see if the link described above, causes link switching unit 420 to switch 

is active. If so, this activity is reported in step 732 and 5 bom G/MII PHY 440 to SERDES PHY 430. The SERDES 

method 700 returns to step 712. If the link is inactive, PHY fe configured and de-isolated in step 830. Method 800 

method 700 proceeds directly to step 712 from step 730. ^en returns to step 722 of method 700 via step 832. 

If it is determined in step 724 that the PHY being * f the switc 0 h Jf determined to be to a G/MII PHY in step 

configured has not completed auto-negotiation, a setup 820, method 800 proceeds to step 826, in which a value 

procedure is performed in step 726. Furthermore, the auto- 10 15 wntteD t0 switch m P ut dala s *g Qal 505 b V control ™* 500 

negotiation process is restarted. Method 700 then returns to ™* causes link switching unit 420 to begin transmitting and 

step 712. When the auto-negotiation process completes, a receiving data to G/MII PHY 440. Next, control unit 500 

CPU interrupt will be generated which indicates that the link wntes a <0 value l ° mlerface data si 6 nal ™ s 

is now active causes sublayer 516 to be selected and sublayer 514 to be 

w . - nA . u j c 1 5 de-selected within unit 412. The G/MII PHY is configured 

Method 700 thus provides a continuous process for mom- 15 . . . , . . . t c ,„ w 4 . , ork ~ . ^ * t 

4 . , ... i i- i ■ -aa and de -isolated in step 830. Method 800 then returns to step 

tonne and switching network inks in computer system 200 c ... . ( Y 

. 6 „ . . % i K J 722 of method 700 via step 832. 

using network interface card 212. . . , t ; . , , . 

It is noted that although only a single G/MII device is 

FIG. 10 — Dynamic Switching Process shown in the preceding figures, a plurality of such devices 

Referring qow to FIG. 10, a method 800 is depicted which 20 nuy be used in other embodiments of NIC 212. Thus, the 

illustrates The switching procedures between two network ^n^"!, "J V v^nlTuu^ * 

links coupled to a network interface card such as NIC 212. SERDES dev,ce and a plurality of G/MII PHYs. 

As described above, method 800 corresponds to step 720 of FIG. 11 — Auto-polling Unit 

FIG. 9. Method 800 handles both switching from the TBI to described above with reference to step 712 of method 

the G/IIM, as well as switching from the G/MII to the TBI. 700> there are various met hods for monitoring the status of 

Unlike prior art designs, this switching process (TBI to an established network link. One commonly practiced pro- 

G/MII or vice-versa) may be accomplished without having cedure ^ l0 Qave a CPU ( such as hosl cpy 2 Q2) repeatedly 

to power-down the system. p0 U a status register within the physical interface layer (such 

Method 800 commences with step 812, in which a new ^ as the PCS) of a PHY device in order to determine if an 

PHY is selected from a previously generated table in the interrupt condition has occurred. While functional, this 

network driver which lists available PHYs. With a new PHY procedure can cause a drain on CPU bandwidth. A more 

selected, a determination is made in step 814 as to whether efficient process for interrupt detection (auto-polling) is 

an interface switch is to be performed. In the context of step described below with reference to FIGS. 11-14. It is noted 

814, "interface switch" refers to a switch from SERDES to 35 that the auto-polling technique described herein maybe used 

GIMII or vice-versa. Switching from one G/MII device to in conjunction with or independently from the dynamic 

another G/MII device is not considered an interface switch switching technique described above, 

for the purposes of step 814. FIG. 11 is a block diagram depicting portions of computer 

If an interface switch is determined not be performed in system 200, specifically portions of network interface card 

step 814, method 800 proceeds to step 815, in which an 40 212. As shown, NIC 212 includes control unit 500, which 

indication is given that the currently selected PHY is about couples to bridge chip 205 via IO bus 214. NIC 212 further 

to go off-line. This allows current link partners to properly includes an auto -polling unit 920, a management interface 

terminate the link connection. Next, the current PHY is logic unit 930, and one or more PHY interface devices 940 

isolated in step 817. In one embodiment, isolation is per- (two are shown in FIG. 11 for purposes of illustration). Note 

formed by writing to a control register within the PHY. 45 that each of interface devices 940 may be internal to the 

Execution of step 817 effectively terminates the current link. actual PHY device (in the case of a G/MII PHY) or external 

With the current link terminated in step 817, method 800 (such as for a SERDES PHY, in which the status registers are 

continues with step 830. In step 830, the new PHY located within interface unit 412, for example), 

(previously selected in step 812) is configured and Each of sublayers 940 includes a control register 942 and 

de-isolated. At the conclusion of step 830, the switching 50 a status register 944. Host CPU 202 is configured to perform 

process is complete. Method 800 continues with step 832, writes to a control register of the currently selected PHY in 

which returns to step 722 of method 700. order to change the operating state of the device. For 

If a determination is made in step 814 that an interface example, the control register for PHY devices has bits 

switch is to be performed, method 800 continues with steps corresponding to reset, power-down, and isolation modes. 

816 and 818. These steps are identical to steps 815 and 817 55 These bits may be set accordingly as needed to achieve a 

described above. At the conclusion of step 818, the current desired state. 

network connection is terminated. If the switch operation of The status registers 944A-B of sublayers 940 include 
method 800 is from TBI to G/MII, physical coding sublayer information which specifies the current state of the link. For 
514 is effectively isolated in step 818 from both the MUX example, status register specified for G/MII PHYs include a 
512A and the control unit 500. 60 variety of bits which may change during operation of the 
In step 820, a determination is made of the whether the link. Bit 5 of the status register indicates whether auto- 
switch is from TBI to G/MII or vice-versa. If the switch is negotiation functionality has completed. Bit 4 indicates the 
to a SERDES PHY, method 800 proceeds to step 822, in presence of a remote fault in auto-negotiation capable PHY 
which a ' 1' value is written to interface select data signal 507 devices. Bit 2 indicates the link status. Bit 1 indicates that 
by control unit 500. In turn, interface select signal 536 65 jabber has been detected on the link, 
becomes a *1\ which causes sublayer 514 to be selected and The interface to the control and status registers of the 
sublayer 516 to be de-selected within physical layer inter- PHY device is referred to as the "management interface". As 
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used herein, a "management interface" is an interface over cycles on MDC 932 during which there is no activity oa 

which control and data values governing device operation MDIO 934. In another embodiment of the invention, the 

are transmitted. The PHY management interface is defined timeout may be adjusted by host CPU 202 as desired, 

by IEEE standard 802.3u, clause 22, to be two-wire inter- when a counter timeout is detected in state 1006, state 

face: a clock signal MDC and a bi-directional data line 5 machine 1000 transitions to state 1008, in which an auto-poll 

MDIO. These signals (represented by reference numerals rca d operation is performed. This involves auto-polling unit 

932 and 934) couple management interface logic unit 930 920 accessing the status register 944 of the currently 

and each of sublayers 940. selected PHY device via the management interface. As part 

In order to write one of control registers 942, host CPU of this process, auto-polling unit 920 sets bus status 936 to 

conveys data to control unit 500 via IO bus 214. The control 10 indicate that the management interface is currently not 

value is then conveyed to management interface logic unit available to the host CPU but holds the request of the host 

930 via bus 938. The new control value is then written to the CPU. (Likewise, when bus status 936 indicates that host 

desired control register 942 via serial data line 934. During CPU is utilizing the management interface, auto-polling unit 

this access, bus status 936 is set to indicate that host CPU is 920 is inhibited from accessing status registers 944). 

utilizing the management interface. (As will be described 15 The value read from the status register 944 of the cur- 

below, auto-polling unit 920 may also utilize the manage- rently selected PHY device is conveyed to auto-poll registers 

ment interface. During such accesses, bus status 936 is set 916A-B via management interface logic unit 930. The 

accordingly. Unit 920, however, cannot utilize the manage- contents of auto-poll data register 916A are then conveyed 

ment interface if bus status 936 indicates that the CPU is t0 comparator 912, which also receives the contents of host 

already using the interface.) The host CPU also performs 20 CPU data register 914. As described above, register 914 

reads of status registers 944 via the management interface. includes the most recent status register value read by the host 

When a status value is accessed from a register 944, the CPU. 

value is stored in host CPU data register 914 for subsequent ^ ^ oil fead of ^ mg 912 

use. Note that the status value read from one of registers 944 forms a of lne current status value (from 

is conveyed to the host CPU via ^multiplexer 922, which 25 f ^ ^ ^ ^ ^ ^ ^ 

selects the input from register 914 as Us output unless host cpu , f there fe a mismatch detected ^tween the two 

interrupt signal 924 is asserted. values - n %Mt mo sme machine im generates M 

As shown, auto-polling unit 920 includes a host CPU data interrupt to the host CPU in state 1012 via PHY interrupt 

register 914, an auto-poll data register 916A, an auto-poll signal 924. The state machine then proceeds to state 1014, 

hold data register 916B, an auto-poll control unit 918, an where it remains until interrupt signal 924 is cleared. 

™ l\T S! daU mul f li P Iexer aDd a comparator (bit m hosl cpu nds lQ thc ^ of [q{ { si , 

XOR) 912. Operation of auto-polling unit 920 is governed 924 b ti a read of thc status ^: data which 

according to an ^to-polling state machine described below c&used mc ^ ^ datfl fa c cd to thc host CPU 

with reference to FIG. 12. Generally speaking auto-poUing from a u faold daU r ^ 916B vift multiplcxcr 922 . 

unit 920 monitors activity on MDIO signal 934 f no ^ fcad t b ^ cpu ^ causcs ^ 9U ^ 

activity is detected for a predetermined number of MDC 916A tQ daU thc samc yalue ^ {n ^ has ^ cffcc| 

cycles, auto-polling unit 920 takes control of the manage- of ^.^i ^ t si ai 924 , sincc the ^ { te t0 

ment interface and queries the status register of the currently comparator 912 arc now equal, 

selected PHY device. If a difference is detected between the „ M 

, , , , A tU • „,„,„,. „„i„^ j . „ 40 When interrupt signal 924 is de-asserted, state machine 

current status value and the previous status value read by , . % 6 ' , ^ . 

u«„. r-ni r in-* „ ar>arn ^ A duv 1000 transitions from state 1014 to state 1016. This state 

host CPU 202, an interrupt is generated on PHY interrupt , , , 

1 oi/i -ru- v « ~..~a /-"Di 7 in -i „■ resets the counter timeout and returns to monitoring state 

signal 924. This interrupt is conveyed to CPU 202 via r ,. „. . , , 6 

7 (1 ■ m n 1006. In this manner, auto-poll mc is disabled while interrupt 

interrupt logic vlU. . 

signal 924 is asserted. 

FIGS. 12-13 — Operation of Auto-polling Unit 45 Operation of state machine 1000 continues as described 

. 4 • above until auto-polling is disabled. It is noted that the above 

Refernng now to RG. 12, a state machine 1000 is , mj. ii- • * ui -.u mrv 

l j m_ \- e * 11* . n-ift described auto-polling process is compatible with any PHY 

depicted which describes operation of auto-polling unit 920 , ,. , . r f T ccc » j j oa<* 1 \ 

L • 41 ^. , t r. l ■ device which incorporates the IEEE standard 802. 3u, clause 

shown in FIG. 11. The start state of stale machine is 1002, „ 4 . \ r ~ . ... . 

, . . , e , ,. .. 22, management interface. The process is compatible since 

ic 1 which the auto-polhng feature is d.sabled. State machine 50 MDIQ ^ MDC ^ nQ( ^ ^ MtindlnJ 

1000 remains in state 1002 until such time as auto-polling is J 

manner 

enabled by host CPU 202 (causing a transition to state 

1004) FIG. 13 presents the operation of auto-polling unit 920 in 

State machine 1000 remains in state 1004 until host CPU flowchart format * 

202 performs one or more writes which cause a particular 55 FIG. 14— Host CPU Operation During Auto- 

PHY to become active. (Specifically, these writes remove Polline 
the PHY from reset, power-down, and isolation modes). 

When host CPU 202 begins writing a PHY, auto-polling unit Referring now lo FIG. 14, a method 1200 is depicted 
920 is able 10 determine the address of the PHY device that which illustrates the operation of a host CPU such as CPU 
it will eventually poll. Auto-polling does not begin, go 202 during the auto-polling procedure. Method 1200 corn- 
however, until the PHY is valid. mences with an initial step 1202. During initialization, 
When a PHY is valid, state machine 1000 transitions to method 1200 proceeds to step 1204, in which auto-polling is 
state 1006. Auto-polling control unit 918 begins monitoring enabled. In one embodiment, auto-polling is enabled when 
activity on the management interface of the currently a valid PHY is discovered. 

selected PHY. The state machine remains in state 1006 until 65 With auto-polling enabled, the host CPU no longer has to 

a counter timeout is detected. In a preferred embodiment of continually monitor the PHY status registers to check for an 

the invention, this counter timeout corresponds to 32 clock interrupt. Instead, auto-polling unit 920 informs the host 
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CPU when a PHY interrupt has been generated. This has the 
desirable effect of reducing CPU overhead. 

When the host CPU receives a PHY interrupt on signal 
924, method 1200 proceeds to step 1208, in which the host 
CPU performs a read operation. In one embodiment, step 
1208 includes sub-steps 1208A-B. 

In sub-step 1208A, the host CPU receives the data the 
caused the interrupt. As described above, this data is con- 
veyed to the CPU via register 91 6B and interrupt status 
register data bus 926. Next, in sub-step 1208B, the host CPU 
performs a read operation which causes interrupt signal 924 
to be de-asserted. This is performed in one embodiment by 
updating the contents of registers 914 and 916B lo the same 
value. With the PHY interrupt cleared, method 1200 returns 
to step 1206. 

Although the auto-polling process described above was 
described as part of a network interface card, this process 
may be utilized by any device that wants to monitor the 
status of a PHY without over-burdening the CPU. 
Furthermore, the process can be expanded to monitor a 
larger set of registers. In an alternate embodiment, the host 
CPU can select one or more registers to auto -poll. Still 
further, the counter timeout may also be adjusted as needed 
by the CPU. This delay could be set to a fixed value if 
desired. In another embodiment, the delay could be set as 
needed by the host CPU. 

Although the system and method of the present invention 
have been described in connection with the described 
embodiments, it is not intended to be limited to the specific 
form set forth herein, but on the contrary, it is intended to 
cover such alternatives, modifications, and equivalents, as 
can be reasonably included within the spirit and scope of the 
invention as defined by the appended claims. 

What is claimed is: 35 

1. A computer system, comprising: 
a host CPU; 

an IO interface device coupled to said computer system 
via a management interface; 

an auto -polling unit configured to monitor activity on said 40 
management interface, wherein said auto-polling unit is 
configured to read a first status value from a status 
register within said 10 interface device in response to 
detecting a lack of activity on said management inter- 
face over a predetermined interval; 

wherein said auto-polling unit is further configured to 
compare said first status value to a second status value, 
wherein said second status value is a most recent status 
value read by said host CPU from said status register; 

wherein said auto-polling unit is configured to generate an 
interrupt to said host CPU in response to detecting a 
mismatch between said first status value and said 
second status value. 

2. The computer system of claim 1, wherein said auto- 
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perform a comparison between said current values from said 
host CPU data register and said auto-poll data register, 
wherein said comparator is configured to generate said 
interrupt in response to detecting a mismatch between said 
current values from said host CPU data register and said 
auto-poll data register. 

5. The computer system of claim 1, wherein said host 
CPU is configured to perform a request for a read of said 
status register in response to receiving said interrupt, 
wherein said auto-polling unit is configured to convey said 
first status vahie to said host CPU in response to said request. 

6. The computer system of claim 5, wherein said auto- 
polling unit is configured to clear said interrupt in response 
to said host CPU performing said request. 

7. The computer system of claim 1, wherein said prede- 
termined interval is variable. 

8. The computer system of claim 7, wherein said prede- 
termined interval is set by said host CPU. 

9. The computer system of claim 1, wherein said auto- 
polling unit monitoring activity on said management inter- 
face is suspended while said interrupt is asserted. 

10. The computer system of claim 1, wherein said man- 
agement interface is usable to set control values within said 
IO interface device, wherein said control values govern 
operation of said IO interface device. 

11. A computer system, comprising: 
a host CPU; 

a network interface device coupled between a first trans- 
mission medium and a management interface to said 
computer system; 

an auto-polling unit configured to monitor activity on said 
management interface of said network interface device, 
wherein said auto -polling unit is configured to read a 
first status value from a status register within said 
network interface device in response to detecting a lack 
of activity on said management interface over a pre- 
determined interval; 

wherein said auto -polling unit is further configured to 
compare said first status value to a second status value, 
wherein said second status value is a most recent status 
value read by said host CPU from said status register; 

wherein said auto-polling unit is configured to generate an 
interrupt to said host CPU in response to detecting a 
mismatch between said first status value and said 
second status value. 

12. The computer system of claim 11, wherein said 
interrupt is indicative of an interrupt condition in a first 
communications channel which includes said network inter- 
face device and said first transmission medium. 

13. The computer system of claim 12, wherein said status 
register includes indications of conditions selected from the 
group consisting of: (i) state of auto-negotiation state 
machine, (ii) a remote fault generated in auto-negotiation 
capable PHY devices, (iii) link status, and (iv) jabber 



polling unit includes a host CPU data register configured lo 55 detection, 

store said most recent status value read by said host CPU 14. The computer system of claim 11, wherein said 

from said status register, wherein said host CPU data register network interface device is a physical layer interface (PHY) 

is configured to store said second status value. device. 

3. The computer system of claim 2, wherein said auto- 15. The computer system of claim 14, wherein said status 

polling unit includes an auto-poll data register configured to 60 register is a PHY status register. 



store a most recent status value read by said auto-polling unit 
from said status register, wherein said auto-poll data register 
is configured to store said first status value. 

4. The computer system of claim 3, wherein said auto- 
polling unit includes a comparator coupled to receive current 65 
values from said host CPU data register and said auto-poll 
data register, wherein said comparator is configured to 



16. The computer system of claim 11, wherein said first 
transmission medium is selected from the group consisting 
of: (i) fiber-optic cable, (ii) unshielded twisted-pair (UTP) 
cable and (iii) coaxial cable. 

17. The computer system of claim 11, wherein said 
management interface includes a clock signal and a serial 
data signal. 
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18. The computer system of claim 17, wherein said lack 
of activity on said management interface is detected by said 
auto -polling unit detecting no data transfers on said serial 
data signal for a predetermined number of cycles on said 
clock signal. 5 

19. The computer system of claim It, wherein said 
management interface is usable to set control values within 
said network interface device, wherein said control values 
govern operation of said network interface device. 

20. The computer system of claim 11, wherein said 10 
auto-polling unit includes a host CPU data register config- 
ured to store said most recent status value read by said host 
CPU from said status register. 

21. The computer system of claim 20, wherein said 
auto -polling unit includes a first auto -polling data register 15 
configured to store a most recent status value read by said 
auto-polling unit from said status register. 

22. The computer system of claim 21, wherein said 
auto-polling unit includes a second auto-polling data register 
also configured to store said most recent status value read by 20 
said auto-polling unit from said status register. 

23. The computer system of claim 22, wherein said 
auto-polling unit further includes a comparator coupled to 
receive current values from said host CPU data register and 
said first auto- polling data register, wherein said comparator 25 
is configured to assert said interrupt in response to detecting 

a mismatch between said current values. 

24. The computer system of claim 23, wherein said host 
CPU is configured to perform a request for said first status 
value in response to receiving said interrupt. 30 

25. The computer system of claim 24, wherein said 
request for said first status value also operates to cause said 
host CPU data register and said first auto-polling data 
register to update to a common value. 

26. The computer system of claim 25, wherein said host 35 
CPU data register and said first auto-polling data register 
updating to said common value operates to clear said 
interrupt. 

27. The computer system of claim 23 wherein said 
auto-polling unit is configured to supply said first status 40 
value from said second auto-polling data register in response 

to receiving said request for said first status value from said 
host CPU. 

28. The computer system of claim 11, further comprising 

a network interface card, wherein said network interface 45 
card includes said network interface device and said auto- 
polling unit. 

29. The computer system of claim 28, wherein said 
auto-polling unit is included in a LAN controller unit within 
said network interface card. 50 

30. The computer system of claim 29, further comprising 
an IO controller coupled between said host CPU and said 
network interface card. 

31. The computer system of claim 11, wherein said 
auto-polling unit is configured to continue monitoring activ- 55 
ity on said management interface of said network interface 
device in response to said first status value being equal to 
said second status value. 
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32. The computer system of claim 11 , wherein said status 
register is a first status register of a plurality of status 
registers within said network interface device, and wherein 
said host CPU is configured to determine which of said 
plurality of status registers is to be read for interrupt deter- 
mination. 

33. A method for generating an interrupt in a computer 
system which includes a host CPU, an IO interface device, 
and an auto-polling unit, said method comprising: 

said auto-polling unit monitoring activity on a manage- 
ment interface coupled to said IO interface device; 

said auto-polling unit detecting a lack of activity on said 
management interface over a predetermined interval; 

said auto-polling unit reading a first status value from a 
status register within said IO interface device; 

said auto -polling unit comparing said first status value to 
a second status value, wherein said second status value 
is a most recent status value read by said host CPU 
from said status register; 

said auto-polling unit generating said interrupt to said host 
CPU in response to detecting a mismatch between said 
first status value and said second status value. 

34. The method of claim 33, further comprising continu- 
ing said monitoring in response to detecting a match 
between said first status value and said second status value. 

35. The method of claim 33, further comprising said host 
CPU requesting a read of said status register in response to 
receiving said interrupt. 

36. The method of claim 35, further comprising said 
auto-polling unit returning said first status value in response 
to said host CPU requesting said read of said status register. 

37. The method of claim 36, further comprising clearing 
said interrupt in response to said host CPU requesting said 
read of said status register. 

38. A computer system configured to perform auto-polling 
of a network interface device, comprising: 

a host CPU; 

an auto-polling unit; 

a network interface device; 

wherein said host CPU is configured to enable said 
auto-polling unit to perform auto-polling of said net- 
work interface device; 

wherein said auto-polling unit is configured to poll said 
network interface in response to detecting a lack of 
activity on a management interface of said network 
interface device, and wherein said auto-polling unit is 
configured to signal an interrupt to said host CPU in 
response to delecting a status value which indicates an 
interrupt condition; 

and wherein said host CPU is configured to read said 
status value which caused said interrupt condition; 

and wherein said host CPU is configured to de-assert said 
interrupt in response to reading said status value. 

***** 
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